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TITLE OF THE INVENTION 
DATA TRANSFER APPARATUS AND METHOD, 
AND DATA TRANSFER SYSTEM AND MEDIUM 

5 BACKGROUND OF THE INVENTION 

FIELD OF THE INVENTION 

This invention relates to a data transfer 
apparatus and method and a data transfer system and 
10 medium and, more particularly, to a data transfer 

apparatus and method in a system in which a plurality of 
devices are connected by a serial bus, and a data 
transfer system and medium. 

15 DESCRIPTION OF THE RELATED ART 

Multifunctional image processing devices have 
remarkably been developed along with recent digital 
copying machines and copying machine systems. Composite 
functions are being advanced such that the copying 

20 machine is integrated with a facsimile function and 
connected to a network to add a printer function. 

Fig. 2 shows an example of the configuration of an 
office network including a conventional digital copying 
machine. In Fig. 2, reference numeral 200 denotes a 

25 network such as an Ethernet to which network devices 

such as an office personal computer, printer and digital 
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copying machine are connected; 201, a personal computer 
(to be referred to as a PC hereinafter) serving as a 
server connected to the scanner of a digital copying 
machine 202; 202, a digital copying machine; 203, a 
5 controller for connecting the digital copying machine to 
the network; 204, a color copying machine; 205, a 
controller for connecting the color copying machine 204 
to the network; 206 and 207, network printers; and 208, 
209, 210, 211, 212 and 213, PC clients connected to the 

10 network 200. 

To perform printout on the PC client side in this 
network environment, printout data is sent after the 
client selects the network printer 206 or 207, the 
digital copying machine 202 via the controller 203, or 

15 the color copying machine 204 via the controller 205. If 
the processing speed of the digital copying machine 202 
is insufficient for obtaining a large number of copies 
by the digital copying machine, printout data can be 
output to the network printers 206 and 207 via the 

20 network 200. 

In the conventional network system, however, a 
large amount of data flows through the network in 
addition to printout data. Particularly when- a large 
amount of image data or the like flows, the throughput 

25 of the whole network greatly decreases. 

Even if a job of a specific user or printer is to 



be preferentially done, this control is difficult to 
perform on a network involving in many communications, 
resulting in low job throughput for the preferential 
device . 

5 

SUMMARY OF THE INVENTION 



Accordingly, it is an object of the present 
invention to provide a data transfer apparatus and 

10 method for avoiding a decrease in network throughput 

caused by transfer of a large amount of data, and a data 
transfer system and medium. 

According to the present invention, the foregoing 
object is attained by providing a data transfer 

15 apparatus for transferring data to a plurality of 

devices connected by a serial bus, comprising band width 
calculation means for calculating a band width necessary 
for data transfer in a specific device out of the 
plurality of devices; first channel ensuring means for 

20 ensuring a first channel corresponding to the band 
width; and first transfer means for performing data 
transfer about the specific device using the first 
channel . 

This apparatus can avoid a decrease in network 
25 throughput by transfer of a large amount of data. 

And it is another object of the present invention 
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to provide a data transfer apparatus and method capable 
of executing preferential job processing for a specific 
device in the network, and a data transfer system and 
medium . 

5 According to the present invention, the foregoing 

object is attained by providing a data transfer 
apparatus further comprising monitoring means for 
monitoring a usage of the specific device by the first 
channel, and the first channel ensuring means ensures 

10 the first channel again in accordance with the usage of 
the specific device. 

This apparatus enables preferential job processing 
for a specific device in the network. 

The invention is particularly advantageous since 

15 an isochronous channel for a specific device in a 
network using a 1394 serial bus can be ensured and 
maintained in the network to preferentially process a 
job related to this device. That is, the device can be 
permitted to preferentially use the network. 

20 Hence, the network can be efficiently used to 

provide a data transfer apparatus and method for 
avoiding a decrease in network throughput caused by 
transfer of a large amount of data, and a data transfer 
system and medium. 

25 Other features and advantages of the present 

invention will be apparent from the following 



description taken in conjunction with the accompanying 
drawings , in which like reference characters designate 
the same or similar parts throughout the figures thereof. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The accompanying drawings, which are incorporated 
in and constitute a part of the specification, 
illustrate embodiments of the invention and, together 
with the description, serve to explain the principles of 
the invention. 

Fig. 1 a diagram showing the configuration of a 
network print system in an embodiment according to the 
present invention; 

Fig. 2 is a diagram showing the configuration of a 
conventional office network; 

Fig. 3 is a block diagram showing the detailed 
construction of a controller; 

Fig. 4 is a block diagram showing the detailed 
construction of a raster image mapping card; 

Fig. 5 is a block diagram showing the detailed 
construction of a network interface card; 

Fig. 6 is a block diagram showing the detailed 
construction of an image network interface card; 

Fig. 7 is a block diagram showing the detailed 
construction of a printer; 



Fig. 8 is a chart showing transition of transfer of 
commands and image data between the controller and 
printer ; 

Fig. 9 is a flowchart showing image data transfer 
5 processing in the controller; 

Figs. 10A and 10B are views showing the 
construction of transfer data; 

Fig. 11 is a timing chart showing a transfer data 
print operation; 
10 Fig. 12 is a flowchart showing initialization 

processing for a 1394 serial bus in the controller; 

Fig. 13 is a block diagram showing an example of a 
network system constructed with an IEEE 13 94 serial 
interface; 

15 Fig. 14 is a block diagram showing the construction 

of the IEEE 1394 serial interface; 

Fig. 15 is an explanatory view showing address 
space of the IEEE 1394 serial interface; 

Fig. 16 is a cross-sectional view showing a cable 
20 for the IEEE 1394 serial interface ; 

Fig. 17 is a timing chart explaining a Data/Strobe 
Link method; 

Fig. 18 is a flowchart showing processing of bus- 
reset to determination of node ID; 
25 Fig. 19 is a flowchart showing determination 

processing of child-parent relation at bus-reset; 
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Fig. 20 is a flowchart showing determination 
processing of node ID after determining of child-parent 
relation at bus -reset; 

Fig. 21 is a block diagram showing an example of 
the network ; 

Fig. 22A and 22B are block diagrams explaining 
arbitration in the IEEE1394 serial bus; 

Fig. 23 is a flowchart explaining arbitration ; 

Fig. 24 is a timing chart showing transitional 
statuses in asynchronous data transfer; 

Fig. 25 is a diagram showing an example of a packet 
format for the asynchronous transfer ; 

Fig. 26 is a timing chart showing transitional 
statuses in isochronous data transfer; 

Fig. 27 is a diagram showing an example of a packet 
format for the isochronous transfer; 

Fig. 28 is a timing chart showing transitional 
statuses in data transfer on the serial bus when the 
isochronous transfer and asynchronous transfer are 
mixedly performed; 

Fig. 29 is a table showing the format of a node 
attribute table generated in the controller ; 

Fig. 3 0 is a table showing an example of the node 
attribute table ; and 

Fig. 31 is a flowchart showing data transfer 
processing in a preferential data transfer mode. 



DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 



Preferred embodiments of the present invention 
5 will now be described in detail in accordance with the 
accompanying drawings . 

<First Embodiment> 

The first embodiment employs an interface defined 
10 by the IEEE 1394 standard (to be referred to as a "1394 
serial bus") as a digital I/F for connecting respective 
devices. The 1394 serial bus will be generally described 
in advance. 

[Outline of 1394 Serial Bus] 

15 With the appearance of general digital video cam 

recorder (VCR) and digital video disk (DVD) player, 
there is a need for transferring realtime and large 
amount data such as video data and audio data 
(hereinafter referred to as "AV data"). To transfer AV 

20 data in realtime to a personal computer (PC) or other 

digital devices, an interface capable of high-speed data 
transfer is required. The 1394 serial bus has been 
developed from the above purpose. 

Fig. 13 shows an example of a network system 

25 constructed with a 1394 serial bus. This system 

comprises devices A to H, and the devices A and B, the 
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devices A and C, the devices B and D, the devices D and 
E, the devices C and F, the devices C and G, and the 
device C and H are respectively connected by a twisted 
pair cable for the 1394 serial bus. These devices A to H 
may be computers such as a personal computer, or most 
computer-peripheral devices such as a digital VCR, a DVD 
player, a digital still camera, a storage device using a 
storage medium such as a hard disk or an optical disk, a 
monitor such as a CRT or an LCD, a tuner, an image 
scanner, a film scanner, a printer, a MODEM, and a 
terminal adapter (TA) , a Set-Top-Box, a digital 
television, a conference camera, a digital video system 
and a complex machine of them. 

Note that the printing method of the printer may be 
any method, e.g., a laser-beam printing, an 
electrophotographic method using an LED, an ink- jet 
method, a thermal -transfer method of ink melting or ink 
sublimation type and a thermo- sensitive printing method. 

The connection between the devices may be made by 
intermixing a daisy chain method and a node branching 
method, thus realizing high-freedom of connecting. 

The respective devices have an ID, and they 
construct a network by identifying each ID within a 
range connected by the 1394 serial bus. For example, the 
devices, respectively, take a relaying role when 
connected in a daisy-chain with cables for the 1394 



serial bus, thus constructing a network. 

As the 1394 serial bus corresponds to Plug and Play 
function, it automatically recognizes a device connected 
to the cable, thus recognizes connection status. In the 
system as shown in Fig . 13 , when a device is removed 
from the network, or a new device is added to the 
network, the bus is automatically reset (i.e., the 
current network constructing information is reset) , and 
a new network is constructed. This function enables 
realtime setting and recognition of network construction. 

The 1394 serial bus has a data transfer speed 
defined as 100/200/400 Mbps. A device having a high 
transfer speed supports a lower transfer speed, thus 
maintaining compatibility. As data transfer modes, an 
asynchronous transfer mode (ATM) for transferring 
asynchronous data such as control signals, an 
isochronous transfer mode for transferring isochronous 
data such as realtime AV data are available. In data 
transfer, within each cycle (generally 125 ms/cycle) , a 
cycle start packet (CSP) indicating the start of cycle 
is transferred, and then asynchronous and isochronous 
data are mixedly transferred such that the isochronous 
data transfer is transferred prior to the asynchronous 
data. 

Fig. 14 shows the construction of the 1394 serial 
bus, as a layer structure. As shown in Fig. 14, a 
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connector port 1710 is connected to a connector at the 
end of a cable 1713 for the 1394 serial bus. A physical 
layer 1711 and a link layer 1712 in a hardware unit 1700 
are positioned as upper layers with respect to the 
connector port 1710. The hardware unit 1700 comprises 
interface chips. The physical layer 1711 performs coding, 
connection-related control and the like, and the link 
layer 1712, packet transfer, cycle-time control and the 
like. 

In a firmware unit 1701, a transaction layer 1714 
manages data to be transferred (transaction data) , and 
outputs commands Read, Write and Lock. A management 
layer 1715 in the firmware unit 1701 manages connection 
statuses and ID'S of the respective devices connected to 
the 1394 serial bus, thus manages the network 
construction. The above hardware and firmware units 
substantially construct the 1394 serial bus. 

In a software unit 1702, an application layer 1716, 
differs in software used by the system, and the data 
transfer protocol indicating how to transfer data on the 
interface is defined by a protocol such as a printer 
protocol or an AV/C protocol . 

Fig. 15 shows address space of the 1394 serial bus. 
All the devices (nodes) connected to the 13 94 serial bus 
have a unique 64 bit address. The 64 bit address is 
stored in a memory of the devices . Data communication 



with a designated destination device can be performed by 
always recognizing the node addresses of the 
transmitting- and receiving-side nodes . 

Addressing of the 1394 serial bus is made based on 
the IEEE 1212 standards, such that first 10 bits are 
allocated for designating a bus number, then next 6 bits 
are allocated for designating an node ID. The remaining 
48 bits are the address width allocated to the device, 
and can be used as unique address space. For instance, 
the last 28 bits may be used as a unique data area for 
storing a device identification data or usage-condition 
designation data. 

The 1394 serial bus has the construction as 
described above. Next, the features of the 1394 serial 
bus will be described in more detail. 

[Detail Description of 1394 Serial Bus] 
«Electrical Specification of 1394 Serial Bus» 

Fig. 16 shows a cross-section of the cable of the 
1394 serial bus. The 1394 serial cable comprises two 
sets of twisted pair signal lines and two power-source 
lines . This construction enables power supply to a 
device which lacks a power source, or a device where a 
voltage is degraded due to a failure or the like. The 
direct-current voltage supplied by the power-source 
lines is 8 to 40V; the current is maximum 1.5 A. Note 
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that in the standards for so-called DV cable, four lines 
except the power-source line construct the cable. 
«DS-Link» 

Fig. 17 is a timing chart explaining a DS-Link 
(Data/ Strobe-Link) method as a data transfer method. 

The DS-Link method, appropriate for high-speed 
serial data communication, requires two sets of two 
signal lines. That is, one of the two sets of twisted- 
pair signal lines is used for sending a data signal, and 
the other one set of twisted-pair signal lines is used 
for sending a strobe signal. On the receiving side, an 
EXCLUSIVE-OR between the data signal and the strobe 
signal is obtained so as to generate a clock signal. In 
the DS-Link transfer, it is unnecessary to mix a clock 
signal into a data signal, therefore, transfer 
efficiency is higher than that in other serial -data 
transfer methods. Further, as a clock signal is 
generated from the data signal and the strobe signal, a 
phase locked loop (PLL) circuit can be omitted, which 
attains downsizing of the scale of a controller LSI . 
Further, in the DS-Link transfer, it is unnecessary to 
send information indicative of idle status when there is 
no data to be transferred, therefore, a transceiver of 
each device can be set in a sleep status, which reduces 
electric consumption. 
<<Bus-Reset Seguence» 



- 13 - 



The respective devices (nodes) connected to the 
1394 serial bus are provided with a node ID, and are 
recognized as nodes constructing the network. For 
example, when increase/decrease of the number of nodes 
due to connection/disconnection or power ON/OFF status 
of network devices, i.e., network construction changes 
and it is necessary to recognize a new network 
construction, the respective nodes detect the change of 
network construction, send a bus-reset signal onto the 
bus, and enter a mode for recognizing the new network 
construction. The detection of change of network 
construction is made by detecting change of bias voltage 
at the connector port 810. 

When the bus -reset signal is sent from one node, 
the physical layer 811 of the respective nodes receives 
the bus-reset signal, and at the same time, notifies the 
link layer 812 of the occurrence of bus reset, and 
forwards the bus-reset signal to the other nodes. When 
all the nodes have received the bus-reset signal, a bus- 
reset sequence is started. Note that the bus -reset 
sequence is started when the cable is attached/detached, 
or the hardware unit 800 has detected network 
abnormality or the like. Further, the bus-reset sequence 
is also started by a direct instruction to the physical 
layer 811 such as host control by a protocol. As the 
bus-reset sequence is started, data transfer is 
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suspended during the bus reset, and after the bus reset, 
the data transfer is restarted in the new network 
cons true t i on . 

«Node-ID Determination Sequence» 

After the bus reset, the respective nodes start to 
obtain a node ID so as to construct a new network 
construction. A general sequence from the bus reset to 
node-ID determination will be described with reference 
to the flowcharts of Figs. 18 to 20. Note that this 
operation is realized by the link layer 1712 which 
generates a topology map of the network structure. 

Fig. 18 is a flowchart showing a sequence from 
occurrence of bus-reset signal to node-ID determination 
and data transfer. At step S101, the respective nodes 
always monitor occurrence of bus-reset signal. When the 
bus-reset signal has occurred, the process proceeds to 
step S102, at which to obtain a new network construction 
in a state where the network construction has been reset, 
parent-child relation is declared between nodes 
connected to each other. Step S102 is repeated until it 
is determined at step S103 that the parent-child 
relation has been determined among all the nodes. 

As the parent-child relation has been determined, 
the process proceeds to step S104, at which one "root 
(node)" is determined. At step S105, node-ID setting is 
performed so as to provide an ID to the respective nodes . 
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The node-ID setting is made in a predetermined order of 
the nodes. Step S105 is repeated until it is determined 
at step S106 that the ID's have been given to all the 
nodes . 

As the node- ID setting has been completed, since 
the new network construction has been recognized by all 
the nodes, data transfer among the nodes is possible. At 
step S107, data transfer is started, and the process 
returns to step S101, at which occurrence of bus-reset 
signal is monitored again. 

Fig. 19 is a flowchart showing the sequence from 
the monitoring of bus-reset signal (S101) to the root 
determination (S104) in detail. Fig. 20 is a flowchart 
showing the node-ID setting (S105 and S106) in detail. 

In Fig. 19, at step S201, the occurrence of bus- 
reset signal is monitored, and as the bus-reset signal 
has occurred, the network construction is reset. Next, 
at step S202, as a first step for re-recognizing the 
reset network construction, the respective devices reset 
its flag FL with data indicative of "leaf (node) " . At 
step S203, the respective devices examine the number of 
ports, i.e., the number of other nodes connected to them. 
At step S204, based on the result of examination at step 
S203, the devices examine the number of undefined (i.e., 
parent-child relation has not been determined) ports. 
The number of undefined ports is equal to that of the 
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ports immediately after the bus reset, however, with the 
progress of determination of parent-child relation, the 
number of undefined ports detected at step S204 
decreases . 

Only actual leaf (ves) can declare parent-child 
relation immediately after the bus reset. Whether or not 
the node is a leaf is detected from the number of ports 
examined at step S203; i.e., if the number of ports is 
"1", the node is a leaf. The leaf declares that "this 
node is a child, and the connected node is a parent" at 
step S205, then terminates the operation. 

On the other hand, a node that detected at step 
S203 that the number of ports is "two or more" is a 
"branch" . Immediately after the bus reset, as "undefined 
ports > 1" holds, the process proceeds to step S206, at 
which the flag FL is set with data indicative of 
"branch", then declaration of parent-child relation from 
another node is waited at step S207. When the parent- 
child relation is declared from another node, the 
process returns to step S204 at which the branch 
examines the number of undefined ports. If the number of 
undefined ports is "1", the branch can declare at step 
S205 that "this node is a child, and the connected node 
is a parent" to the node connected to the remaining port. 
If the number of undefined ports is still "two or more", 
the branch waits for declaration of parent-child 
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relation from another node at step S207. 

When any one of the branches (or exceptionally 
leaf (ves) which delayed declaring a child) detects that 
the number of undefined ports is "0", the parent-child 
declaration of the overall network has been completed. 
The only node that has "0" undefined port, i.e., the 
parent of all the nodes, sets the flag FL with data 
indicative of a "root" at step S208. Then at step S209, 
the node is recognized as a root. 

In this manner, the procedure from the bus reset to 
the parent-child declaration among all the nodes in the 
network ends . 

Next, a procedure of providing each node with an ID 
will be described. First, the ID setting is performed at 
the leaves. Then, ID'S are set in numerical order (from 
node number: 0) from leaves -> branches — * root. 

In Fig. 20, at step S301, the process splits in 
accordance with node type, i.e., leaf, branch or root, 
based on the data set at the flags FL. 

In case of leaf, at step S3 02, the number of leaves 
(natural number) in the network is set to a variable N. 
At step S3 03, the respective leaves request a node 
number to the root. If a plurality of requests have been 
made, the root performs arbitration at step S304, and 
provides a node number to one node at step S305, while 
notifies the other nodes of the result of acquisition of 
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node-number indicating that the node number has been 
failed, 

A leaf that has not obtained a node number (NO at 
step S3 06) repeats the request for node number at step 
S3 03. On the other hand, a leaf that has obtained a node 
number notifies all the nodes of the obtained node 
number by broadcasting ID information including the node 
number. As the broadcasting of the ID information has 
been completed, the variable N indicative of the number 
of leaves is decremented at step S3 08. Then, from the 
determination at step S309, the procedure from step S303 
to step S3 08 is repeated until the variable N becomes 
"0" in the determination at step S309. When ID 
information on all the leaves have been broadcasted, the 
process proceeds to step S3 10, for setting ID'S of 
branches . 

The ID setting for branches is performed 
substantially similar to the ID setting for the leaves. 
First, at step S310, the number of branches (natural 
number) is set to a variable M. At step S3 11, the 
respective branches request the root for a node number. 
In response to the requests, the root performs 
arbitration at step S312, and provides a node number, 
subsequent to the last leaf node number, to a branch at 
step S313, while notifies the other branches of the 
result of acquisition of node-number indicating that the 
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node number has been failed. 

A branch that has not obtained a node number (NO at 
step S3 14) repeats the request for node number at step 
S3 15. On the other hand, a branch that has obtained a 
node number notifies all the nodes of the obtained node 
number by broadcasting ID information including the node 
number. As the broadcasting of the ID information has 
been completed, the variable M indicative of the number 
of branches is decremented at step S316. Then, from the 
determination at step S317, the procedure from step S311 
to step S3 16 is repeated until the variable M becomes 
"0" in the determination at step S3 17. When ID 
information on all the leaves have been broadcasted, the 
process proceeds to step S3 18, for setting the ID of the 
root . 

At this time, it is only the root that has not 
obtained a node ID. At step S3 18, the root obtains the 
smallest number that has not been provided to any other 
node as the node ID of the root, and at step S319, 
broadcasts ID information on the root. 

As described above, the procedure until the node 
ID'S for all the nodes have been set ends. Next, the 
sequence of node ID determination will be described with 
reference to the network example shown in Fig. 21. 

In the network in Fig. 21, a node B as a root is 
directly connected to its lower nodes A and C; the node 
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C is directly connected to its lower node D; and the 
node D is directly connected to its lower nodes E and F. 
The procedure of determining this hierarchical structure, 
the root node and the node ID'S will be described below. 

After the bus reset has occurred, to recognize 
connection statuses of the respective nodes, parent- 
child relation is declared between ports of directly 
connected nodes, "parent" means a node at an upper level 
and "child" means a node at a lower level in the 
hierarchical structure. In Fig. 21, the node that first 
declared parent-child relation after the bus reset is 
the node A. As described above, nodes (leaves) where 
only one port is connected can start declaration of 
parent-child relation. That is, if the number of ports 
is "1", it is recognized that the node is the end of the 
network tree, i.e., a leaf. The declaration of parent- 
child relation is started from the leaf which has first 
taken action among these leaves. Thus, a port of the 
leave node is set as a "child", while the port of 
another node connected to the leave node is set as a 
"parent" . In this manner, "child-parent" relation is 
sequentially set between the nodes A and B, between the 
nodes E and D, and between the nodes F and D. 

Further, among upper nodes having a plurality of 
ports, i.e., branches, parent-child relation is 
sequentially declared with respect to upper node(s), 



from the node that first received declaration of parent- 
child relation from the leaf. In Fig. 21, first parent- 
child relation is determined between the nodes D and E 
and between the nodes D and F. Then the node D declares 
parent-child relation with respect to the node C, and as 
a result, a relation "child-parent" is set between the 
nodes D and C. The node C, that has received the 
declaration of parent-child relation from the node D, 
declares parent-child relation with respect to the node 
B connected to the other port, thus "child-parent" 
relation is set between the nodes C and B. 

In this manner, the hierarchical structure as shown 
in Fig. 21 is constructed as a topology map by the link 
layer 1712. The node B, that has finally become the 
parent at all the ports, is determined as a root. Note 
that a network has only one root. In a case where the 
node B that has received declaration of parent-child 
relation from the node A immediately declares parent- 
child relation with respect to another node, the other 
node, e.g., the node C, may be the root node. That is, 
any node may be a root depending upon timing of 
transmitting declaration of parent-child relation, and 
further, even in a network maintaining the same 
construction, a particular node is not always become a 
root . 

As the root has been determined, the sequence of 
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determining the respective node ID'S is started. Each 
node has a broadcast function to notify its ID 
information to all the other nodes . ID information 
includes a node number, information on a connected 
position, the number of ports, the number of ports 
connected to other nodes, information on parent-child 
relation on the respective ports and the like. 

As described above, the assignment of node numbers 
is started from the leaves. In numerical order, node 
number = 0, 1, 2,.... is assigned. Then, by the 
broadcasting of ID information, it is recognized that 
the node number has been assigned. 

As all the leaves have obtained a node number, node 
numbers are assigned to the branches. Similar to the 
assignment of node numbers to the leaves, ID information 
is broadcasted from the branch that received a node 
number, and finally, the root broadcasts its ID 
information. Accordingly, the root always has the larger 
node number. 

Thus, as the ID setting of the overall hierarchical 
structure has been completed and the network has been 
constructed, then the bus initialization is completed. 
«Arbitration» 

Next, the bus arbitration in the physical layer 
1711 will be described. 

The 1394 serial bus always performs arbitration of 



a bus -use right prior to data transfer. The devices 
connected to the 1394 serial bus respectively relay a 
signal transferred on the network, thus constructing a 
logical bus-type network transmitting the signal to all 
the devices within the network. This necessitates bus 
arbitration to avoid packet conflict. As a result of bus 
arbitration, one node can transfer data during a certain 
period. 

Figs. 22A and 22B are block diagrams explaining 
the bus arbitration. Fig. 22A shows operation to request 
a bus use right; and Fig. 22B, operation to allow to use 
the bus . 

When the bus arbitration is started, a single or 
plurality of nodes respectively request a bus use right 
to use the bus to its parent node. In Fig. 22A, the 
nodes C and F request a bus use right. The parent node 
(node A in Fig. 22A) that has received the request 
relays the request by further requesting a bus use right 
to its parent node. The request is forwarded to a root 
that finally performs arbitration. 

The root node that has received the request for 
bus use right determines a node to be provided with the 
bus use right . This arbitration can be performed only by 
the root node . The node that dominated in the 
arbitration is provided with the bus use right. Fig. 22B 
shows that the node C has obtained the bus use right and 
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the request from the node F has been rejected. 

The root sends a DP (data prefix) packet to nodes 
lost in the bus arbitration so as to notify that their 
requests have been rejected. The requests from those 
nodes are held by the next bus arbitration. 

Thus, the node that obtained the bus use 
permission starts data transfer. 

The sequence of the bus arbitration will be 
described with reference to the flowchart of Fig. 23. 

To start data transfer by a node, the bus must be 
in idle status . To confirm that data transfer has been 
completed and the bus is currently in idle status, each 
node detects a gap length of a predetermined idle period 
(e.g., sub-action gap) set in each transfer mode, and it 
determines whether or not the bus is currently in idle 
status based on the detection result. 

At step S401, the node determines whether or not a 
predetermined gap length corresponding to asynchronous 
data or isochronous data to be transferred has been 
detected. So far as the node has not detected the 
predetermined gap length, it cannot request a bus use 
right to start data transfer, accordingly, the node 
waits until the predetermined gap length has -been 
detected. 

When the predetermined gap length has been 
detected at step S401, the node determines whether or 
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not there is data to be transferred at step S402. If YES, 
it issues a signal requesting a bus use right to the 
root at step S403 . As shown in Fig. 22, this signal 
requesting the bus use right is relayed by the 
respective devices in the network, and forwarded to the 
root. If it is determined at step S402 that there is no 
data to be transferred, the process returns to step S401. 

At step S404, if the root has received a single or 
plurality of request signals for the bus use right, it 
examines the number of nodes requesting the bus use 
right at step S405. From the determination at step S405, 
if the number of the nodes requested the bus use right 
is one, that node is provided with bus use permission 
immediately after the requirement. On the other hand, if 
the number of the nodes is more than one, arbitration is 
performed to determine one node to be provided with the 
bus use right immediately after the requirement. The 
arbitration does not always provide a bus use right to 
the same node, but equally provides a bus use right to 
the respective nodes (fair arbitration) . 

The processing at the root node branches at step 
S407 into processing for the node dominated in the 
arbitration at step S406, and processing for the other 
nodes lost in the arbitration. In a case where there is 
one node that requested the bus use right, or one node 
has dominated in the arbitration, the node is provided 
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with an permission signal indicative of bus use 
permission at step S408. The node starts data (packet) 
transfer immediately after it receives the permission 
signal (step S410) . On the other hand, the nodes lost in 
the arbitration receive a DP (data prefix) packet 
indicative of rejection of the bus use request at step 
S409. The processing for the node that received the DP 
packet returns to step S401 to request a bus use right 
again. Also, the processing for the node that completed 
data transfer at step S410 returns to step S401. 
«Asynchronous Sub-action» 

The asynchronous transfer mode (ATM) which is one 
of the data transfer modes with 1394 serial bus will be 
described below. 

The asynchronous sub- act ion is asynchronous data 
transfer. 

Fig. 24 shows transition in the asynchronous 
transfer. In Fig. 24, the first sub-action gap 
represents the idle status of the bus. At a point where 
the idle time has become a predetermined value, a node 
which is to perform data transfer requests a bus use 
right, then bus arbitration is executed. 

When the use of bus has been allowed by the 
arbitration, data in the form of packet is transferred, 
and a node which receives the data sends a reception 
acknowledgment code ACK as a response, or sends a 



response packet after a short gap called ACK gap, thus 
the data transfer is completed. The code ACK comprises 
4 -bit information and a 4 -bit checksum. The code ACK, 
including information indicative of success, busy or 
pending status, is immediately sent to the data-sender 
node . 

Fig. 25 shows a packet format for asynchronous 
transfer. The packet has a data area, a data CRC area 
for error correction, and a header area in which a 
destination node ID, a source node ID, a transfer data 
length and various codes are written. 

The asynchronous transfer is one-to-one 
communication from a sender node to a receiver node. A 
packet sent from the sender node is relayed by the 
respective nodes in the network, however, as these nodes 
are not designated as the receiver of the packet, they 
ignore the packet, then only the receiver node 
designated by the sender node receives the packet. 
<<Isochronous Sub-action» 

The isochronous transfer mode (ITM) which is an 
another data transfer modes with 1394 serial bus will be 
described below. 

The isochronous sub-action is isochronous data 
transfer. 

Isochronous transfer, which can be regarded as the 
greatest feature of the 1394 serial bus is appropriate 
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to multimedia data transfer which requires realtime 
transfer of, especially, AV data. 

Further, the asynchronous transfer is one-to-one 
transfer, whereas the isochronous transfer is 
broadcasting transfer from one sender node to all the 
other nodes . 

Fig. 26 shows transition in the isochronous 
transfer. The isochronous transfer is executed on the 
bus in a predetermined cycle, called "isochronous cycle". 
The period of the isochronous cycle is 125 |j,s . A cycle 

start packet (CSP) indicates the start of the 
isochronous cycle for synchronizing the operations of 
the respective nodes. When data transfer in a cycle has 
been completed and a predetermined idle period (sub- 
action gap) has elapsed, a node which is called "cycle 
master" sends the CSP indicative of the start of the 
next cycle. That is, this interval between the issuance 
of CSP's is 125 jxs. 

As channel A, channel B and channel C in Fig. 26, 
the respective packets are provided with a channel ID, 
so that plural types of packets can be independently 
transferred within one isochronous cycle. This enables 
substantially-real time transfer among the plural nodes. 
The receiver node can receive only data with a 
predetermined channel ID. The channel ID does not 
indicate an address of the receiving node, but merely 
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indicates a logical number with respect to the data. 
Accordingly, one packet sent from a sender node is 
transferred to all the other nodes, i.e., broadcasted. 

Similar to the asynchronous transfer, bus 
arbitration is performed prior to the packet 
broadcasting in isochronous transfer. However, as the 
isochronous transfer is not one-to-one communication 
like the asynchronous transfer, the reception 
acknowledgment code ACK used as a response in the 
asynchronous transfer is not used in the isochronous 
transfer. 

Further, an isochronous gap (iso gap) in Fig. 26 
represents an idle period necessary for confirming prior 
to isochronous transfer that the bus is in idle status. 
If the predetermined idle period has elapsed, bus 
arbitration is performed with respect to node(s) 
desiring isochronous transfer. 

Fig. 27 shows a packet format for isochronous 
transfer. Various packets divided into channels 
respectively have a data field, a data CRC field for 
error correction and a header field containing 
information such as a transfer-data length, a channel 
No., various codes and error-correction header CRC as 
shown in Fig. 27. 
«Bus Cycle» 

In practice, both isochronous transfer and 
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asynchronous transfer can be mixedly performed on the 
1394 serial bus. Fig. 28 shows transition in the 
isochronous transfer and asynchronous transfer mixedly 
performed on the 1394 serial bus. 

The isochronous transfer is performed prior to the 
asynchronous transfer because after the CSP, the 
isochronous transfer can be started with a gap 
(isochronous gap) shorter than the idle period necessary 
for starting the asynchronous transfer. Accordingly, the 
isochronous transfer has priority over the asynchronous 
transfer. 

In the typical bus cycle as shown in Fig. 28, upon 
starting the cycle #m, a CSP is transferred from the 
cycle master to the respective nodes. The operations of 
the respective nodes are synchronized by this CSP, and 
node(s) that waits for a predetermined idle period 
(isochronous gap) to perform isochronous transfer 
participates in bus arbitration, then starts packet 
transfer. In Fig. 28, a channel e, a channel s and a 
channel k are transferred by the isochronous transfer. 

The operation from the bus arbitration to the 
packet transfer is repeated for the given channels, and 
when the isochronous transfer in the cycle #m has been 
completed, the asynchronous transfer can be performed. 
That is, when the idle period has reached the sub-action 
gap for the asynchronous transfer, node(s) that is to 
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perform the asynchronous transfer participates in bus 
arbitration. Note that only if the sub-action gap for 
starting the asynchronous transfer is detected, after 
the completion of isochronous transfer and before the 
next timing to transfer the CSP (cycle synch) , the 
asynchronous transfer can be performed. 

In the cycle #m in Fig. 28, the isochronous 
transfer for three channels is performed, and then two 
packets (packet 1 and packet 2) including ACK are 
transferred by the asynchronous transfer. When the 
asynchronous packet 2 has been transferred, as the next 
cycle synch point to start the subsequent cycle m+1 
comes, the transfer in the cycle #m ends. Note that 
during the asynchronous or isochronous transfer, if the 
next cycle synch point to transfer the next CSP has come, 
the transfer is not forcibly stopped but continued. 
After the transfer has been completed, a CSP for the 
next cycle is transferred after a predetermined idle 
period. That is, when one isochronous cycle is continued 
for more than 125 |xs, the next isochronous cycle is 
shorter than the reference period 125 jxs . In this manner, 

the isochronous cycle can be lengthened or shortened 
based on the reference period 125 jxs . 

However, it may be arranged such that the 
isochronous transfer is performed in every cycle, while 
the asynchronous transfer is sometimes postponed until 
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the next cycle or the cycle further subsequent to the 
next cycle, so as to maintain realtime transfer. The 
cycle master also manages information on such delay. 



5 [Print System] 

A print system according to the first embodiment 
will be described by mainly exemplifying a digital 
copying machine controller as a constituent. 
«General Configuration of System» 

10 Fig. 1 is a diagram showing the general 

configuration of the print system to which a plurality 
of image processing devices including a digital copying 
machine are connected by a network in the first 
embodiment. In Fig. 1, reference numeral 100 denotes a 

15 network such as an Ethernet connected to personal 

computers and printers; 101, a network (to be referred 
to as an image network) for transferring images; and 102, 
an image data controller (to be simply referred to as a 
controller hereinafter) for controlling input/output of 

20 image data. Reference numeral 103 denotes a color 
copying machine; 104 and 105, printers; and 106, a 
monochrome digital copying machine. The components 103 
to 106 are connected to the image network 101. Reference 
numerals 107, 108, 109, 110, 111 and 112 denote personal 

25 computers (to be referred to as PCs) connected to the 

network 100. In printout from the PC side, image data is 
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sent to a desired printer or copying machine via the 
network 100, controller 102 and image network 101. 

The controller 102 will be explained. Fig. 3 is a 
block diagram showing the construction of the controller 
5 102. In Fig. 3, reference numeral 301 denotes a CPU on 
the controller 102 , which controls 
transmission/reception of data to/from the PC and 
printer in the network. Reference numeral 302 denotes a 
data bus for the CPU 301, which is connected to a card 

10 bus controller 304, ROM 305, RAM 306 and hard disk 

controller 3 07 (to be described next) . The card bus 
controller 3 04 controls a card bus 303 for mounting a 
functional board for adding a function to the controller 
102. The ROM 305 is a program memory storing control 

15 software of the controller 102 . Part of the program area 
is formed from a flash ROM to allow a rewrite from a 
FAX • data modem 311 (to be described later) or interface 
terminal (not shown) via a telephone line. The RAM 306 
is formed from a DRAM or SRAM, is generally used as a 

20 program work area, and can also be used as an image data 
memory. The hard disk controller 3 07 controls a 
read/write from/in a hard disk 312. The hard disk 312 is 
used to accumulate image data and store program software. 
In accumulating image data, image data compressed by the 

25 .hard disk controller 307 is stored in the hard disk 312. 
In reading out the compressed data from the hard disk 
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312, data is expanded by the hard disk controller 307. 

Respective functional boards connected to the card 
bus 303 will be explained. Reference numeral 308 denotes 
a network interface card which controls an interface for 
5 the network 100 connected to the PCs 107 to 112 and 

controller 102 shown in Fig. 1. The network interface 
card 308 makes it possible to install a corresponding 
card to a physical interface constructing the network 
100 such as an Ethernet or token ring. An image network 

10 interface card 309 controls an interface for the image 
network 101 for performing transmission/reception of 
image data between the color copying machine 103, 
printers 104 and 105 and monochrome digital copying 
machine 106, and the controller 102 shown in Fig. 1. 

15 The image network 101 must be constituted by a 

high-speed bus capable of transferring a large amount of 
image data. For this purpose, the first embodiment 
employs the aforementioned 1394 serial bus capable of 
high-speed transfer to the image network 101. However, 

20 the image network 101 is not limited to the 1394 serial 
bus, and can adopt any bus so long as a large amount of 
data can be transferred at high speeds. 

A raster image mapping card 310 is used for 
mapping to bitmap data of a page descriptive language 

25 (PDL) . The raster image mapping card 310 is not used 
when the printers 104 and 105 in the image network 101 
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can individually cope with the PDL. However, when, e.g., 
a so-called dam printer for only printing bitmap data is 
connected to the image network 101, the raster image 
mapping card 310 can be used to allow the PCs 107 to 112 
5 in the network 100 to use the dam printer as a PDL 

printer. The printer can cope with various kinds of PDLs 
by replacing a functional board in the card bus. Further, 
when the program memory area of the raster image mapping 
card 310 is made rewritable, like a flash ROM or RAM, 

10 and raster image mapping programs for a plurality of 
PDLs are stored in the hard disk 312 in advance, the 
user can load a desired PDL from the hard disk 312 to 
the program memory of the raster image mapping card 310. 
The FAX • data modem card 311 is connected to a 

15 telephone line to realize facsimile 

transmission/reception as a FAX modem or to realize 
communication with a remote PC or work station as a data 
modem . 

«Data Flow on Network» 
2 0 Operation of the controller 102 and a data flow in 

the network 100 will be described by exemplifying a case 

where PDL data is transmitted from the PCs 107 to 112 in 

the network 100 and printed out. 

Assume that the PC 107 shown in Fig. 1 selects the 
25 printer 105 and designates PDL printing. In this case, 

PDL data output from the PC 107 is input to the 



controller 102 via the network 100. The PDL data is 
input to the raster image mapping card 310 via the 
network interface card 3 08 shown in Fig. 3. 

Fig. 5 is a block diagram showing the detailed 
5 construction of the network interface card 308. 

Reference numeral 701 denotes a card bus interface; 702, 
an Ethernet controller for controlling a popular 
Ethernet protocol; 703, a RAM used as a data 
transmission/reception buffer; 704, an Ethernet 

10 transceiver including an interface part with a 

network-connected medium such as 110base2 or lObaseT; 
and 705, a connector corresponding to the network medium. 

If the CPU 301 in the controller 102 determines 
that data transferred via the network interface card 308 

15 is PDL data, it transfers the data to the raster image 
mapping card 310. 

Fig. 4 is a block diagram showing the detailed 
construction of the raster image mapping card 310. 
Reference numeral 601 denotes a card bus interface; 602, 

20 a raster image processor for mapping PDL data into 

bitmap data; 603, a ROM serving as a program area for 
the raster image processor; 604, a bitmap memory for 
storing bitmap data; and 605, a bitmap memory controller 
for controlling a read/write from/ in the bitmap memory 

25 604. The PDL data input to the raster image mapping card 
310 is sent via the card bus interface 601 to the raster 
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image processor 602 where bitmap data is generated and 
stored in the bitmap memory 604 via the bitmap memory 
controller 605. The bitmap data thus mapped in the 
raster image mapping card 310 is transferred to the 
5 image network interface card 309. 

Fig. 6 is a block diagram showing the detailed 
construction of the image network interface card 309. 
Reference numeral 801 denotes a card bus interface; 802, 
a first-in first-out memory (to be referred to as a 

10 FIFO) for transferring image data; 803, a link 

controller chip (to be referred to as a 1394 link 
controller) for the 1394 serial bus serving as a high- 
speed serial interface adopted in the first embodiment ; 
804, a physical interface (to be referred to as a 13 94 

15 physical interface) for the 1394 serial bus; and 805, 
connectors to which interface cables of the image 
network 101 are connected. The connectors 805 allow 
connecting three cables in maximum to one 1394 physical 
interface 804. 

20 The CPU 301 of the controller 102 transfers data 

in the procedure from a to f via the image network 
interface card 309 in order to transfer bitmap data to 
the printer 105 designated by the PC 107 . At the 
following steps a to f, data is transferred in the arrow 

25 direction, and the content of transfer data is given in 
() - 
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a. Controller 102 -»• Printer 105 
(Data Transmission Request Command) 

b. Printer 105 -»• Controller 102 

(Data Reception Acknowledgment Command) 
5 c. Controller 102 -* Printer 105 

(Print Data Start Command) 

d. Controller 102 -»• Printer 105 
(Bitmap Data) 

e. Controller 102 -* Printer 105 
10 (Print Data End Command) 

f . Printer 105 — ► Controller 102 

(Print Data Reception Acknowledgment Command) 
As described above, the data transfer mode of the 
1394 serial bus includes the asynchronous transfer mode 

15 where data is transferred to a predetermined transfer 

destination and the data receiving side sends back data 
reception acknowledgment, and the isochronous transfer 
mode where data is transferred to an unspecified 
transfer destination and the receiving side does not 

20 send back any acknowledgment. The first embodiment 

transfers commands in the asynchronous transfer mode and 
bitmap data as image data in the isochronous transfer 
mode . 

In the image network interface card 3 09 shown in 
25 Fig. 6, command data is input to the 1394 link 

controller 803 via the card bus interface 801 and 
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transferred as asynchronous data. On the other hand, 
bitmap data is temporarily written in the FIFO 802 via 
the card bus interface 801. The 1394 link controller 803 
reads out and transfers the bitmap data from the FIFO 
5 802 in order to transfer the bitmap data in the 
isochronous transfer mode. 

The construction of the printer 105 will be 
explained. Fig. 7 is a block diagram showing the 
detailed construction of the printer 105. Reference 

10 numeral 901 denotes a CPU for performing all controls in 
the printer 105 such as mechatronics control and 
reception of bitmap data; 902, a ROM storing control 
programs of the CPU 901; 903, a RAM used as a work area 
of the CPU 901; 904, a CPU address bus & data bus for 

15 the CPU 901; 905, a 1394 link controller for controlling 
an interface with the image network 101 formed from the 
1394 serial bus; 906, a 1394 physical interface; 907, a 
connector; 908, a FIFO for temporarily storing 
isochronously transferred bitmap data; 909, a video data 

20 controller for controlling a read of bitmap data from 

the FIFO 908 in accordance with the operation timing of 
a printer engine; 910, a laser driver for performing an 
actual print operation; 911, an engine controller for 
performing mechatronics control such as motor control of 

25 the printer engine or paper feed control; and 912, a 
printer engine . 



Transfer of commands and data between the CPUs and 
link controllers of the controller 102 and printer 105 
will be explained with reference to the transition chart 
of data transfer shown in Fig. 8. In Fig. 8, each of 
5 arrows #1001 to #1013 indicates one transfer. Respective 
transfers will be exemplified below. 

#1001: A data transmission request command is 
transferred from the controller 102 to a desired printer 
(printer 105 in this case) in the asynchronous transfer 
10 mode. 

#1002: The printer 105 receives the data 
transferred in the asynchronous transfer mode and sends 
the acknowledgment (to be referred to as ACK) from the 
1394 link controller 905 of the printer 105 to the link 

15 controller 803 of the controller 102. 

#1003: The CPU 901 of the printer 105 receives a 
data transmission request command. 

#1004: The CPU 901 confirms the current status of 
the printer 105, and if a printout operation is possible, 

20 sends a data transmission request permission command to 
the link controller 803 of the controller 102. The data 
transmission request permission command is transferred 
in the asynchronous transfer mode by the 1394 link 
controller 905. 

25 #1005: The controller 102 sends the ACK of the 

data transmission request permission command from the 
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1394 link controller 803. 

#1006: The CPU 301 of the controller 102 receives 
the data transmission request permission command. 

#1007 : Image data is transferred in the 
5 isochronous transfer mode from the controller 102 to the 
printer 105. Note that this image data transfer will be 
described in detail later. 

#1008: The controller 102 transfers a print data 
end command to the printer 105 upon completion of image 
10 data transfer. 

#1009: The 1394 link controller 905 of the printer 
105 sends back the ACK of the print data end command to 
the link controller 803 of the controller 102. 

#1010: The CPU 901 of the printer 105 receives the 
15 print data end command. 

#1011: The printer 105 sends a print data 
reception acknowledgment command to the controller 102 . 

#1012: The link controller 803 of the controller 
102 sends back the ACK of the print data reception 
20 acknowledgment command to the 1394 link controller 803 
of the printer 105. 

#1013: The CPU 301 of the controller 102 receives 
the print data reception acknowledgment command. 

As described above, commands and image data are 
2 5 respectively transferred in the asynchronous and 

isochronous transfer modes between the controller 102 
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and printer 105 of the first embodiment. 
« Isochronous Transfer of Image Data» 

Isochronous transfer of image data in the first 
embodiment will be explained in detail. 
5 In isochronous transfer, as described above, 

packets are transferred every 125 jls, and channels are 
ensured in advance to assure the data transfer time. 
Therefore, the controller 102 must confirm the 
processing speed (performance) of a printer (printer 105 

10 in the first embodiment) to which data is to be 

transferred, and ensure a channel corresponding to this 
performance. A channel ensuring operation in the 
controller 102 will be explained with reference to the 
flowchart of Fig. 9. 

15 At step S1101, the controller 102 confirms the 

performance of the printer 105. For example, the 
controller 102 confirms the main scanning period (to be 
referred to as a 1H period) in the printer 105 and the 
number of pixels in the 1H period (number of 1H pixels) . 

20 At step S1102, the controller 102 calculates a necessary 
channel width based on the confirmed printer performance. 
For example, when the 1H period is 375 (125 X 3) p,s and 
the number of 1H pixels is 7,200, a data transfer time 
for 7,200/3 = 2,400 pixels must be assured for each pack 

25 at an interval of 125 jls. For example, if the printer 
105 is a binary printer, a data transfer channel for 



2,400 bits is ensured for each packet. After determining 
the necessary channel in this way, the controller 102 
ensures the necessary transfer channel via the link 
controller 803 at step S1103 . 
5 After ensuring the necessary channel for the 

printer 105, the controller 102 generates transfer data 
in an actual transfer format at step S1104 such that 
start and end headers are added to 1-page or 1H image 
data. 

10 The generated transfer data will be explained with 

reference to a detailed example shown in Figs. 10A and 
10B. In Fig. 10A, one packet is formed every 125 Jls , and 
the hatched portion in the packet represents an ensured 
channel. The hatched portion, i.e., ensured channel is 

15 made of a header and image data. The header includes a 
page start code, inter-page code, page end code, 1H 
start code, 1H period code, and 1H end code to allow the 
printer 105 side having received the transferred data to 
recognize the location at which position image data in 

20 the channel is located. For example, when data of 2,400 
pixels out of 7,200 pixels as the number of 1H pixels is 
transferred by one channel of one packet, data of 7,200 
pixels for 1H can be transferred by three packets, i.e., 
three channels . 

25 Fig. 10B is a view showing a more detailed 

construction of the generated transfer data. When image 
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data of n lines (n is a positive integer) is to be 
transferred, data from the first to 3nth packets, i.e., 
data of 3n channels is transferred. As headers, the 
first packet has "AOh" indicating a page start code and 
5 "A8h" indicating a 1H start code in addition to image 
data, the second packet has "A2h" indicating an inter- 
page code and "AAh" indicating a 1H period code in 
addition to image data, the third packet has "A2h" 
indicating an inter-page code and "ADh" indicating a 1H 

10 end code in addition to image data, .... By similarly 
adding headers, transfer data is generated and 
transferred. "A5h" indicating a page end code and "ADh" 
indicating a 1H end code are transferred by the 3nth 
packet in addition to image data, thereby completing the 

15 transfer of 1-page image data. 

Referring back to the flowchart in Fig. 9, if the 
controller 102 has completely generated transfer data, 
the generated transfer data is transferred to the FIFO 
802 in the image network interface card 309 at step 

20 S1105. The FIFO 802 must have a size corresponding to a 
data size transferred by at least one packet. After 
storing the transfer data in the FIFO 802, the 
controller 102 causes the 1394 link controller 803 to 
execute data transfer at step S1106. While a header is 

2 5 added to image data to generate transfer data, as shown 
in Fig. 10, data transfer is repeatedly executed. If 1- 
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page data has completely been transferred, the print 
data transfer is completed. 

The printer 105 prints out the print data 
transferred in this manner. This printout will be 
5 explained with reference to the timing chart shown in 
Fig. 11. #1301 represents the period of a packet 
transferred from the controller 102, and the hatched 
portion represents image data in the isochronous 
transfer mode. #1302 represents the data write timing of 

10 the FIFO 908 in the printer, at which data transferred 
to the 1394 link controller 905 is written in the FIFO 
908. #1303 represents the generation timing of a BD 
signal indicating the start of main scanning in the 
printer 105. In Fig. 11, one BD signal is generated 

15 every three packets. #1304 represents the read timing of 
the FIFO 908. As is apparent from #1304, 3-packet data 
is written in the FIFO 908 and then read out from it in 
synchronism with a next BD timing. #13 05 represents a 
print operation, which is done during a read from the 

20 FIFO 908. 

In this fashion, image data is transferred from 
the controller 102 to the selected printer 105 via the 
image network 101, and printed out. 
<<Initialization of Network>> 

2 5 A device connected to the network via the 1394 

serial bus forms a topology map by the link controller 
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upon energization to recognize all nodes connected to 
the network. At this time, all the nodes are assigned 
with node numbers in accordance with physical connection 
statuses and initial settings, and one root node is 
5 selected. In forming the topology map in the image 
network 101, the map must be initially set to 
necessarily select the controller 102 as a root node. 
Setting the controller 102 to the root node allows 
smooth subsequent management of the image network 101. 
10 Initialization control of the image network 101 by 

the controller 102 set as a root node after a bus reset 
will be explained with reference to the flowchart of 
Fig. 12. 

At step S1501, a bus reset signal for the 1394 
15 serial bus, i.e., image network 101 is generated, and 
all 1394 physical interfaces connected to the image 
network 101 detect the bus reset signal and execute a 
reset cancel sequence. At step S1502, each node in the 
image network 101 performs predetermined control for a 
20 port connected after a predetermined wait time, while 

waiting for assignment of the node number and forming a 
topology map. If the 13 94 link controller 905 of the 
controller 102 is determined at step S1503 not to be a 
root map, the wait time is increased by a predetermined 
25 time at step S1504. The flow returns to step S1501 to 

execute the bus reset sequence again and form a topology 
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map again. In general, a wait time much longer than the 
wait time in a bus reset for a printer, color copying 
machine, monochrome digital copying machine or scanner 
recognized by the controller 102 must be set in the 1394 
5 link controller 905 of the controller 102 in advance. 

Note that determination of whether or not the controller 
102 is a root node at step S1503 must be repeatedly 
performed while increasing the wait time until the 
controller 102 is set to a root node, for the sake of 

10 subsequent management of the image network 101. As a 
matter of course, a predetermined upper limit must be 
set to the wait time. 

If the controller 102 is set as a root node, the 
controller 102 inquires attribute information of each 

15 node in the image network 101 at step S1505. At step 
S1506, the controller 102 forms a node attribute table 
based on the attribute information sent from each node. 
This node attribute table allows the controller 102 to 
determine whether or not image data can be exchanged 

20 with each node, and if data transfer is possible, grasp 
the performance of the node. For example, when a given 
node is a printer, information on the presence/absence 
of a page memory, the resolution, the 1H period, the 
number of 1H pixels, and the print count is held in the 

25 node attribute table. If the controller 102 has 

confirmed attribute information of all nodes at step 
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S1507, formation of the attribute table is completed. 

Since the attributes of all devices in the image 
network 101 are grasped as a node attribute table after 
formation of the topology map in the controller 102, the 
5 command transfer overhead in data transfer can be 
reduced. 

The node attribute table formed at step S1506 will 
be explained with reference to its structure shown in 
Fig. 29 and detailed example shown in Fig. 30. 

10 As described above, the node attribute table is 

formed to manage devices connected to the image network 
101 in the controller 102. The table includes items 
shown in Fig. 29. The item name of the node attribute 
table is given in "". The "node number" is assigned to 

15 each node in forming the topology map. The "transfer 
rate" is one which is supported by the physical 
interface of the 1394 serial bus and is any one of 400 
Mbps, 200 Mbps, and 100 Mbps . The "device type" 
represents whether a node is a device which 

20 transmits/receives image data to/from the controller 102, 
or a device which does not transmit /receive any image 
data. As the device type, a scanner, printer, copier or 
the like is set. The "image data input/output" 
represents the input/output characteristics of image 

2 5 data at the node, and is set as any one of input, output 
and input & output. In other words, if the node is a 
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scanner, the "image data input /output " is set as 
"output" . 

Further, the node attribute table holds the 
scanner and printer attributes of each node. The scanner 
5 attribute means the characteristic of a scanner function 
(image input function) of the node, and the printer 
attribute means the characteristic of a printer function 
(image output function) of the node. As the scanner 
attribute, the "scanner data type" is set as 

10 color /monochrome, and the "scanner resolution (dpi) *' and 
"scanner bit depth (bit/pixel) " are set. As the printer 
attribute, the "printer data type" is set as 
color /monochrome, and the "print speed (ppm) " , "printer 
resolution (dpi) " and "printer bit depth (bit/pixel) " 

15 are set. 

Fig. 3 0 shows a setting example of the node 
attribute table of the color copying machine 103 , 
printers 104 and 105 and monochrome digital copying 
machine 106 in the image network 101. Since the copying 

20 machine has both the scanner and printer functions, it 
is set to " input /output" in the "image data 
input /output " item and managed as an image data 
transmission/reception device by the controller 102. 

Note that device information managed by the node 

25 attribute table is not limited to the items shown in 

Fig. 29. For example, the "power supply ability" item is 
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added to allow the controller 102 to grasp whether or 
not a certain node can supply and receive power via the 
1394 serial bus cable. Needless to say, another device 
information can also be set. 
5 «Preferential Node Setting» 

As a feature of the first embodiment, priority is 
given to a predetermined node in the network by ensuring 
a channel for the isochronous transfer mode on the 1394 
serial bus . The following description is directed to an 

10 example where a job to the color copying machine 103 (to 
be referred to as the copier 103 hereinafter) is 
preferentially processed in the image network 101. 

Note that which of nodes is given priority is 
managed by the controller 102 in the first embodiment. 

15 This setting is performed arbitrarily by a console (not 
shown) of the controller 102 or by a predetermined 
command from any one of the PCs 107 to 112 via the 
network 100. In either case, a preferential node should 
be set by only a specific user, which requires security 

20 management to a certain degree such that a predetermined 
password is set. 

Fig. 31 is a flowchart showing operation of a 
"preferential mode" where data is preferentially 
transferred to the copier 103 in the controller 102. The 

25 processing shown in Fig. 31 is controlled by the 
controller 102. 
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At step S3401, the controller 102 checks whether 
or not the preferential mode is set. If YES at step 
S3401, the controller 102 advances to step S3403. Note 
that the preferential mode can be set by the controller 
102 similarly to the aforementioned preferential node 
setting or by the PCs 107 to 112 via the network 100. If 
NO at step S3401, the controller 102 shifts to step 
S3 402 to perform control in a normal mode where no 
preferential data transfer is done. 

At step S3403, the controller 102 calculates a 
necessary band width in advance on the basis of the 
processing speed of the preferentially set copier 103. 
For example, when 7,200 pixels and 8 bits/pixel are set 
for a 1H period of 375 /is, at least 2,400-byte data must 
be transferred within one cycle of 125 |i.s . In this case, 
a time of 48 lis must be ensured every cycle even with an 
image data transfer rate of, e.g., 400 Mbps . 

The controller 102 proceeds to step S3404 to 
ensure an isochronous channel on the 13 94 serial bus. At 
this step, the controller 102 ensures a channel in 
consideration of data transfer regardless of the 
presence /absence of data to be transferred. The 
controller 102 advances to step S3405 to transfer dummy 
isochronous data to the ensured channel. Since no 
partner node is notified of data reception by 
asynchronous transfer in advance, any node does not 
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receive this dummy isochronous data. The controller 102 
confirms a data transfer request at step S3406, and if 
YES at step S3406, proceeds to step S3407. If NO at step 
S3406, the controller 102 returns to step S3405 to send 
dummy data again in a predetermined cycle and wait for a 
data transfer request. 

If a destination of the data transfer request is 
preferentially set at step S3407, the controller 102 
shifts to step S3408. If NO at step S3407, the 
controller 102 shifts to step S3409 . At step S3408, the 
controller 102 transfers data using the isochronous 
channel ensured in advance because of the data transfer 
request to the preferentially set copier 103. Upon 
completion of data transfer, the controller 102 returns 
to step S3405 to send dummy data and wait for a next 
data transfer request. When data is transferred to a 
node not preferentially set, the controller 102 newly 
ensures an isochronous channel corresponding to this 
data transfer at step S3409. At step S3410, the 
controller 102 transfers data by the newly ensured 
isochronous channel. The controller 102 similarly 
returns to step S3405 to send dummy data and wait for a 
data transfer request. 

Note that the first embodiment has exemplified the 
case where the copier 103 in the image network 101 is a 
preferentially set node (to be referred to as a 
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preferential node hereinafter) . For example, any one of 
the PCs 107 to 112 connected to the network 100 as an 
Ethernet may be set as a preferential node for the 
controller 102. In this case, since a necessary band 
5 width depends on setting from the PC as a preferential 
node, the controller 102 may fail to receive a data 
transfer request other than the preferential node unless 
an excessively large band width is inhibited from being 
preferentially set. Therefore, a band width ensured for 

10 the preferential node must be limited. 

As described above, according to the first 
embodiment, a predetermined node in the image network is 
preferentially set, a band width necessary for the node 
is ensured in advance, and only when a transfer request 

15 to this node is generated, data is transferred using the 
channel. As a result, data can be smoothly transferred 
to the preferentially set node. 

<Modif ication of First Embodiment> 

20 In the first embodiment, one preferential node is 

set in the image network 101 using the 1394 serial bus. 
However, since dummy data is continuously transferred 
until a transfer request to the preferential node is 
generated, the network is wastefully used while no 

25 transfer request to the preferential node is generated. 
For this reason, in actual operation of the image 
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network 101, it is desirable for efficient network use 
to set a plurality of nodes as preferential nodes 
because transfer requests to the preferential nodes are 
frequently generated to decrease the dummy data transfer 
5 frequency. 

In the first embodiment, when a data transfer 
request to a node other than the preferential node is 
generated, a new channel is ensured without using a 
channel ensured for the preferential node. In the 

10 present invention, however, an isochronous channel 
ensured for the preferential node may be used in 
accordance with the data amount of the data transfer 
request. For example, when a band width corresponding to 
the transfer request is equal to or less than half a 

15 band width ensured for the preferential node in advance, 
the transfer request may be permitted to use the channel 
ensured for the preferential node. Also, when the band 
width of the transfer request exceeds half the band 
width for the preferential node but the number of cycles 

20 required to complete data transfer is small, the 

transfer request may be permitted to use the channel for 
the preferential node. In this way, the channel for the 
preferential node can be appropriately used even in data 
transfer to a node other than the preferential node. 

25 The use of the ensured channel is permitted in 

consideration of not only the size of a necessary band 
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width at a node other than the preferential node, as 
described above, but also the utilization factor of the 
preferential node. For example, the number of successive 
dummy data transmission operations is counted, and if 
5 the count exceeds a predetermined value, the utilization 
factor of the preferential node is determined to be low, 
decreasing the ensured band width or cancelling the 
preferential setting. Alternatively, while the 
utilization factor of the preferential node is always 

10 calculated, the band width of the ensured channel may be 
dynamically changed in accordance with the value. 

When the utilization factor of the preferential 
node is low, the preferential setting is canceled; when 
even a node other than the preferential node has a high 

15 utilization factor, this node is newly set as a 

preferential node. In this manner, it is also effective 
to dynamically switch preferential setting in accordance 
with the utilization factor of each node. 

In the above-described embodiment, the image 

2 0 network 101 is constructed using a serial interface 

defined by the IEEE 1394 standard. However, the present 
invention is not limited to this and can be applied to a 
network constructed using an arbitrary serial interface 
such as one called a universal serial bus (USB) . 

25 

<Other Embodiment> 



The present invention can be applied to a system 
constituted by a plurality of devices (e.g., host 
computer, interface, reader, printer) or to an apparatus 
comprising a single device (e.g., copy machine, 
5 facsimile) . 

Further, the object of the present invention can be 
also achieved by providing a storage medium storing 
program codes for performing the aforesaid processes to 
a system or an apparatus, reading the program codes with 
10 a computer (e.g., CPU, MPU) of the system or apparatus 
from the storage medium, then executing the program. 

In this case, the program codes read from the 
storage medium realize the functions according to the 
embodiment /embodiments, and the storage medium storing 
15 the program codes constitutes the invention. 

Further, the storage medium, such as a floppy disk, 
a hard disk, an optical disk, a magneto-optical disk, 
CD-ROM, CD-R, a magnetic tape, a non -volatile type 
memory card, and ROM can be used for providing the 
20 program codes. 

Furthermore, besides aforesaid functions according 
to the above embodiments are realized by executing the 
program codes which are read by a computer, the present 
invention includes a case where an OS (operating system) 
25 or the like working on the computer performs a part or 
entire processes in accordance with designations of the 
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program codes and realizes functions according to the 
above embodiments . 

Furthermore, the present invention also includes a 
case where, after the program codes read from the 
5 storage medium are written in a function expansion card 
which is inserted into the computer or in a memory 
provided in a function expansion unit which is connected 
to the computer, CPU or the like contained in the 
function expansion card or unit performs a part or 
10 entire process in accordance with designations of the 
program codes and realizes functions of the above 
embodiments . 

In a case where the present invention is applied 
to the aforesaid storage medium, the storage medium 
15 stores program codes corresponding to the flowcharts 
described in the foregoing embodiment . 

As has been described above, according to the 
present invention, since an isochronous channel for a 
specific device in a network using the 1394 serial bus 
20 is ensured and maintained in the network using the 1394 
serial bus, it is possible to preferentially process a 
job related to this device. In other words, the device 
can be permitted to preferentially use the network. 
By virtue of the above, the network can be 
25 efficiently used. Accordingly, it is possible to provide 
a data transfer apparatus and method as well as a data 
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transfer system for avoiding a decrease in network 
throughput caused by transfer of a large amount of data. 

As many apparently widely different embodiments of 
the present invention can be made without departing from 
the spirit and scope thereof, it is to be understood 
that the invention is not limited to the specific 
embodiments thereof except as defined in the appended 
claims . 
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WHAT IS CLAIMED IS 

1. A data transfer apparatus for transferring data to 
a plurality of devices connected by a serial bus, 
comprising: 

5 band width calculation means for calculating a 

band width necessary for data transfer in a specific 
device out of the plurality of devices; 

first channel ensuring means for ensuring a first 
channel corresponding to the band width; and 
10 first transfer means for performing data transfer 

about the specific device using the first channel. 

2. The apparatus according to claim 1, wherein the 
specific device is a printer. 

3. The apparatus according to claim 2, wherein said 
15 band width calculation means calculates a band width 

necessary for data transfer in the printer on the basis 
of a processing speed of the printer. 

4 . The apparatus according to claim 3 , wherein the 
processing speed of the printer is based on at least one 

2 0 of a print speed, a print resolution and a printer bit 
depth. 

5 . The apparatus according to claim 3 , wherein the 
processing speed of the printer is based on at least one 
of a main scanning period in printing, the number of 

25 pixels formed in the main scanning period, and the 
number of bits representing one pixel. 
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6. The apparatus according to claim 1, further 
comprising: 

second channel ensuring means for ensuring a 
second channel; and 
5 second transfer means for performing data transfer 

about a device other than the specific device using the 
second channel . 

7. The apparatus according to claim 1, wherein said 
first transfer means performs isochronous transfer. 

10 8. The apparatus according to claim 7, wherein, when 
no data transfer about the specific device is done, said 
first transfer means sends invalid data to the first 
channel . 

9. The apparatus according to claim 1, further 

15 comprising specific device setting means for setting at 
least one of the plurality of devices as the specific 
device . 

10. The apparatus according to claim 9, wherein said 
specific device setting means sets at least two devices 

20 as the specific device. 

11. The apparatus according to claim 7, further 
comprising control means for, when a band width 
necessary for data transfer about a device other than 
the specific device is not more than a predetermined 

25 value, controlling to perform data transfer about the 
device using the first channel. 
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12. The apparatus according to claim 11, wherein the 
predetermined value is half a band width calculated by 
said band width calculation means . 

13. The apparatus according to claim 7, further 

5 comprising control means for, when the number of cycles 
necessary for data transfer about a device other than 
the specific device is not more than a predetermined 
value, controlling to perform data transfer about the 
device using the first channel . 

10 14. The apparatus according to claim 1, further 

comprising monitoring means for monitoring a usage of 
the specific device by the first channel, and 

said first channel ensuring means ensures the 
first channel again in accordance with the usage of the 

15 specific device. 

15. The apparatus according to claim 9, further 
comprising monitoring means for monitoring a usage of 
the specific device by the first channel, and 

said specific device setting means sets the 
20 specific device again in accordance with the usage of 
the specific device. 

16. The apparatus according to claim 9, further 
comprising monitoring means for monitoring usages of the 
plurality of devices, and 

25 said specific device setting means resets the 

specific device in accordance with the usages of the 
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plurality of devices . 

17. The apparatus according to claim 1, wherein said 
first channel ensuring means ensures the first channel 
when the band width is not more than a predetermined 

5 value . 

18. The apparatus according to claim 1, wherein the 
serial bus is a bus complying with an IEEE 1394 standard. 

19. The apparatus according to claim 1, wherein the 
serial bus is a bus complying with a USB standard. 

10 20. A data transfer method in a system in which a 
plurality of devices are connected by a serial bus, 
comprising: 

the band width calculation step of calculating a 
band width necessary for data transfer in a specific 
15 device out of the plurality of devices; 

the first channel ensuring step of ensuring a 
first channel corresponding to the band width; and 

the first transfer step of performing data 
transfer about the specific device using the first 
20 channel. 

21. The method according to claim 20, wherein the 
specific device is a printer. 

22. The method according to claim 21, wherein the band 
width calculation step comprises calculating a band 

25 width necessary for data transfer in the printer on the 
basis of a processing speed of the printer. 
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23. The method according to claim 22, wherein the 
processing speed of the printer is based on at least one 
of a print speed, a print resolution and a printer bit 
depth . 

5 24. The method according to claim 22, wherein the 

processing speed of the printer is based on at least one 
of a main scanning period in printing, the number of 
pixels formed in the main scanning period, and the 
number of bits representing one pixel. 
10 25. The method according to claim 20, comprising: 
the second channel ensuring step of ensuring a 
second channel; and 

the second transfer step of performing data 
transfer about a device other than the specific device 
15 using the second channel. 

26. The method according to claim 20, wherein the 
first transfer step comprises performing isochronous 
transfer. 

27. The method according to claim 26, wherein, when no 
20 data transfer about the specific device is done, the 

first transfer step comprises sending invalid data to 
the first channel . 

28. The method according to claim 20, further 
comprising the specific device setting step of setting 

25 at least one of the plurality of devices as the specific 
device . 
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29. The method according to claim 28, wherein the 
specific device setting step comprises setting at least 
two devices as the specific device. 

30. The method according to claim 26, wherein, when a 
5 band width necessary for data transfer about a device 

other than the specific device is not more than a 
predetermined value, the first transfer step comprises 
controlling to perform data transfer about the device 
using the first channel. 
10 31. The method according to claim 30, wherein the 

predetermined value is half a band width calculated in 
the band width calculation step. 

32. The method according to claim 26, wherein, when 
the number of cycles necessary for data transfer about a 

15 device other than the specific device is not more than a 
predetermined value, the first transfer step comprises 
controlling to perform data transfer about the device 
using the first channel. 

33. The method according to claim 20, further 
20 comprising: 

the monitoring step of monitoring a usage of the 
specific device by the first channel; and 

the channel re-ensuring step of ensures the first 
channel again in accordance with the usage of the 
25 specific device. 

34. The method according to claim 28, further 
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comprising: 

the monitoring step of monitoring a usage of the 
specific device by the first channel; and 

the device resetting step of resetting a specific 
5 device in the plurality of devices in accordance with 
the usage of the specific device. 

35. The method according to claim 28, further 
comprising: 

the monitoring step of monitoring usages of the 
10 plurality of devices; and 

the device resetting step of setting a specific 
device in the plurality of devices again in accordance 
with the usages of the plurality of devices. 

36. The method according to claim 20, wherein the 

15 first channel ensuring step comprises ensuring the first 
channel when the band width is not more than a 
predetermined value. 

37. The method according to claim 20, wherein the 
serial bus is a bus matching or complying with an IEEE 

2 0 1394 standard. 

38. The method according to claim 20, wherein the 
serial bus is a bus matching or complying with a USB 
standard. 

39. A data transfer system for transferring data 

25 between a plurality of devices connected by a serial bus, 
comprising : 
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band width calculation means for calculating a 
band width necessary for data transfer in a specific 
device out of the plurality of devices ; 

first channel ensuring means for ensuring a first 
5 channel corresponding to the band width; and 

first transfer means for performing data transfer 
about the specific device using the first channel. 
40. The system according to claim 39, wherein the 
specific device is a printer. 
10 41. The system according to claim 40, wherein said 
band width calculation means calculates a band width 
necessary for data transfer in the printer on the basis 
of a processing speed of the printer. 

42. The system according to claim 41, wherein the 

15 processing speed of the printer is based on at least one 
of a print speed, a print resolution and a printer bit 
depth . 

43. The system according to claim 41, wherein the 
processing speed of the printer is based on at least one 

20 of a main scanning period in printing, the number of 
pixels formed in the main scanning period, and the 
number of bits representing one pixel . 

44. The system according to claim 39, further 
comprising : 

25 second channel ensuring means for ensuring a 

second channel; and 
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second transfer means for performing data transfer 
about a device other than the specific device using the 
second channel . 

45. The system according to claim 39, wherein said 
5 first transfer means performs isochronous transfer. 

46. The system according to claim 45, wherein, when no 
data transfer about the specific device is done, said 
first transfer means sends invalid data to the first 
channel . 

10 47. The system according to claim 44, wherein the 
plurality of devices include a controller, and each 
means is incorporated in the controller. 

48. The system according to claim 47, further 
comprising specific device setting means for setting at 

15 least one of the plurality of devices other than the 
controller as the specific device. 

49. The system according to claim 48, wherein said 
specific device setting means sets at least two devices 
as the specific device. 

20 50. The system according to claim 48, wherein the 
plurality of devices include a printer. 

51. The system according to claim 48, wherein the 
plurality of devices include a personal computer. 

52. The system according to claim 45, further 
25 comprising control means for, when a band width 

necessary for data transfer about a device other than 



the specific device is not more than a predetermined 
value, controlling to perform data transfer about the 
device using the first channel. 

53. The system according to claim 52, wherein the 

5 predetermined value is half a band width calculated by 
said band width calculation means . 

54. The system according to claim 45, further 
comprising control means for, when the number of cycles 
necessary for data transfer about a device other than 

10 the specific device is not more than a predetermined 
value, controlling to perform data transfer about the 
device using the first channel. 

55. The system according to claim 39, further 
comprising monitoring means for monitoring a usage of 

15 the specific device by the first channel, and 

said first channel ensuring means ensures the 
first channel again in accordance with the usage of the 
specific device. 

56. The system according to claim 48, further 

20 comprising monitoring means for monitoring a usage of 

the specific device by the first channel, and 

said specific device setting means sets the 

specific device again in accordance with the usage of 

the specific device. 
25 57. The system according to claim 48, further 

comprising monitoring means for monitoring usages of the 
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plurality of devices, and 

said specific device setting means resets the 
specific device in accordance with the usages of the 
plurality of devices . 
5 58. The system according to claim 39, wherein said 
first channel ensuring means ensures the first channel 
when the band width is not more than a predetermined 
value . 

59. The system according to claim 39, wherein the 

10 serial bus is a bus matching or complying with an IEEE 
1394 standard. 

60. The system according to claim 39, wherein the 
serial bus is a bus matching or complying with a USB 
standard. 

15 61. A storage medium for storing program codes of data 
transfer processing in a system in which a plurality of 
devices are connected by a serial bus, comprising: 
a code of the band width calculation step of 
calculating a band width necessary for data transfer in 
2 0 a specific device out of the plurality of devices ; 

a code of the first channel ensuring step of 
ensuring a first channel corresponding to the band 
width; and 

a code of the first transfer step of performing 
25 data transfer about the specific device using the first 
channel . 
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ABSTRACT OF THE DISCLOSURE 



In a conventional system to which a plurality of 
devices are connected by a serial bus, the throughput of 
5 the network decreases due to transfer of a large amount 
of data. In this invention, a controller connected to 
the devices via a 1394 serial bus calculates a band 
width necessary for data transfer in a specific one of 
the devices, ensures the first channel corresponding to 
10 the band width, and transfers data to the specific 
device using the first channel . This enables 
preferential data transfer to the specific device to 
avoid a decrease in throughput . 
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